草庐IT

Android HTML ImageGetter 作为 AsyncTask

全部标签

c++ - 使用 std::function 或转发引用作为高阶函数的通用可调用对象输入参数?

我想知道编写一个以std::function作为输入参数的高阶函数的主要区别、优缺点。或转发引用,例如templatevoidhof(F&&fun);.显然,前者比后者更严格,因为它指定了输入可调用对象必须符合的函数类型。 最佳答案 std::function通常具有显着的运行时开销。通过template参数传递通用可调用对象可避免std::function的间接成本,并允许编译器积极优化。我在theendofthisarticle为lambda递归编写了一些简单的基准测试(Y组合器与std::function).std::func

c++ - 为什么不允许位字段作为类的静态数据成员

谁能解释不允许位域作为类的静态成员背后的原因?例如,定义如下的类:classA{public:A(){}~A(){}private:staticintmem:10;};intA::mem;不编译。用不同的编译器编译这个类:-1-g++抛出错误:-错误:静态成员'mem'不能是位域staticintmem:10;错误:‘intA::mem’不是‘classA’的静态数据成员intA::mem;2-clang抛出错误:-错误:静态成员'mem'不能是位域staticintmem:10;3-VisualStudio15抛出错误:-'A::mem'::非法存储类'intA::mem':不允许成

c++ - if constexpr(condition) 作为编译时条件

我想使用constexprbool(下例中的useF)来启用以下代码中的功能。在这里,调用A::f()。此外,我想将别名模板(a)设为void,以防我关闭该功能。我尝试使用constexprif语句,但主体仍在实例化,这导致编译错误。如果我使用包装器模板(X),正文将按照我的预期被丢弃,但这对我来说似乎很难看。还有其他方法吗?constexprbooluseF=false;structA{staticvoidf(){}};usinga=std::conditional::type;templatestructX{staticvoidh(){ifconstexpr(std::is_sam

c++ - 将 lambda 作为参数传递时重载函数

我正在尝试在返回参数为void或T时实现模板函数。我使用sfinae尝试了上述代码的不同变体,但仍然不确定在lamdba是函数参数的情况下这通常是否可行。以下代码无法编译:#includetemplateTApply(conststd::function&func){returnfunc();}templatevoidApply(conststd::function&func){func();}intmain(intargc,char*argv[]){inti1=Apply([](){return10;});boolb1=Apply([](){returntrue;});Apply([

c++ - 非类型模板参数中的占位符类型是否可以涉及作为模板参数传递的函数的重载解析?

thisquestion的后续行动.假设占位符可用于推断构成非类型模板参数的函数指针的结果类型。c++17是否允许对传递给模板函数的名称执行重载解析——在不知道结果类型的情况下执行隐式转换需要这样做?templatestructFoo{};intbar(int);floatbar(float);intmain(){static_cast(Foo{});}[gcc]以及[clang]似乎接受代码。 最佳答案 是的,根据verybulletRakete1111pointedout是允许的.而且没有必要只是假设它可以完成,它是根据占位符类

c++ - 将 std::type_index 作为模板参数传递给函数模板

考虑以下代码(工作正常):namespacefruit{structapple{};}namespacelanguage{structenglish{};}typedefstd::pairmyPairType;std::unordered_mapmyMap={{"paul",{"likes",std::type_index(typeid(fruit::apple))}},{"jonas",{"likes",std::type_index(typeid(language::english))}}};现在我有以下功能模板:templatevoidGenerateProfile(void*d

c++ - 如何在不在 C++ 中创建函数对象的情况下将函数指针作为模板值参数传递?

我在这里看到过这个问题的许多变体,但我仍然觉得我的具体情况有所不同。我的目标是包装一个如下所示的CAPI:TF_Buffer*buf=TF_AllocateBuffer();//...TF_DeleteBuffer(buf);因为我有很多这样的对象,所以我想创建一个名为handle的通用类型,它可以保存给定的指针并在销毁时调用适当的释放器。我想象的用例是classbuffer:publichandle{public:buffer(TF_Buffer*b):handle(b){}}不幸的是,我无法让它工作,因为TF_DeleteBuffer是一个简单的函数(类型为voidTF_Delet

c++ - 不能使用指针作为默认模板参数

我正在尝试使用默认原始指针作为默认模板参数。我读到非类型模板参数仅限于整数类型、枚举、指针和引用。对于引用,我没有遇到任何问题,但是当我尝试使用指针时,我遇到了这样的错误:error:non-typetemplateargumentoftype'Engine*'isnotaconstantexpression.这是我的代码:#include#includeusingstd::cout;usingstd::endl;classEngine{public:voidstartEngine(){m_started=true;coutclassCar{public:explicitCar(con

c++ - 如何调用对象的成员函数作为 std 算法的 unary_function?

我有一个看起来像这样的类。classA{public:voiddoSomething();}我有一组这些类。我想对数组中的每个项目调用doSomething()。使用算法header执行此操作的最简单方法是什么? 最佳答案 使用std::mem_fun_ref将成员函数包装为一元函数。#include#includestd::vectorthe_vector;...std::for_each(the_vector.begin(),the_vector.end(),std::mem_fun_ref(&A::doSomething));

c++ - 将部分专用模板作为模板参数传递

我有一个类模板,需要一些其他模板作为参数:templateclassAllocator>classPolicy>classcontainer{Policy*_policy;//somecodehere};通常我将它与这样的策略类一起使用:templateclassAllocator>classpolicy{//somecode};但是如果我必须将额外的模板参数传递给策略类怎么办?像这样的东西:templateclassAllocator>classpolicy_3{//somecode};我该怎么做,才能让那个类(class)的用户在不接触其他人的情况下通过年龄参数表?例如:typed